## ~\MobaXterm\home\QuartusProjects\Homework\hw8\hw8\_serial\_parser\serial.vhd

```
1 -- Name: Ian Flury
   -- Assignment: HW8, P1 programmable square wave generator.
   -- Class: CPEN430 Digital System Design
   -- Date: 10/18/2023
5
 6
   library ieee;
7
    use ieee.std_logic_1164.all;
    use ieee.std logic unsigned.all;
    use ieee.numeric_std.all;
9
10
    use work.all;
11
12
13
    entity serial is
14
        port (
15
            clock : in std_logic;
16
            RST : in std_logic;
17
            serial : in std_logic;
18
            wave_out : out std_logic
19
        );
20
    end serial;
21
22
    architecture rtl of serial is
23
24
    type state_t is (zero, one, two, three);
25
    signal state, next_state : state_t;
26
27
28
    begin
29
30
        the_machine: process(state, serial, RST)
31
        begin
32
            if RST = '1' then
33
                 wave out <= '0';
34
                     next_state <= zero;</pre>
35
            else
36
                 case state is
37
                     when zero =>
                         if serial = '1' then
38
39
                              next_state <= one;</pre>
40
                         else
41
                                      next_state <= zero;</pre>
42
                                end if;
43
                                wave_out <= '0';</pre>
                     when one =>
44
45
                         if serial = '1' then
46
                              next_state <= two;</pre>
47
                         else
48
                              next_state <= zero;</pre>
49
                         end if;
50
                                wave_out <= '0';
51
                     when two =>
                         if serial = '1' then
52
```

1 of 2 10/26/2023, 10:55 AM

```
53
                                next_state <= three;</pre>
54
                           else
55
                                next_state <= zero;</pre>
56
                           end if;
57
                                  wave_out <= '0';</pre>
58
                      when three =>
59
                           if serial = '1' then
                               wave_out <= '1';</pre>
60
61
                               next_state <= three;</pre>
62
                           else
63
                                        wave_out <= '0';</pre>
64
                                        next_state <= zero;</pre>
65
                                  end if;
                      when others =>
66
67
                  end case;
             end if;
68
69
         end process the_machine;
70
71
         the_registers: process(clock, RST)
72
         begin
73
             if RST = '1' then
74
                  state <= zero;</pre>
75
             elsif clock'EVENT and clock = '1' then
76
                  state <= next_state;</pre>
77
             end if;
         end process the_registers;
78
79
80 end rtl;
```

2 of 2